import PubSub from 'pubsub-js'
import request from '../../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    day: '', // 天
    month: '', // 月
    recommendList: [], // 推荐列表数据
    index: 0, // 点击音乐的下标
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    // 判断用户是否登录
    let userInfo = wx.getStorageSync('userInfo');
    if(!userInfo){
      wx.showToast({
        title: '请先登录',
        icon: 'none',
        success: () => {
          // 跳转至登录界面
          wx.reLaunch({
            url: '/pages/login/login'
          })
        }
      })
    }
    // 更新日期的状态数据
    this.setData({
      day: new Date().getDate(),
      month: new Date().getMonth() + 1
    })
  
    // 获取每日推荐的数据
    this.getRecommendList();

    //订阅来自songDetail页面的消息
    PubSub.subscribe('switchType',(msg,type)=>{
      let {recommendList,index} =this.data
      // 需要找到对应当前的详情index
      if(type==='pre'){ //上一首
        //如果是第一首再点就要跳到最后
        (index===0)&&(index=recommendList.length)
        index -=1
      }else { //下一首
        //如果是最后一首再点就要跳到第一首
        (index===recommendList.length-1)&&(index=-1)
        index +=1
      }
      // 更新下标
      this.setData({
        index
      })
      // 将音乐id 回传给 detail页面
      let musicId = recommendList[index].id
      PubSub.publish('musicId',musicId)
    })
   
  },
  
  // 获取用户每日推荐数据
  async getRecommendList(){
    let recommendListData = await request('/recommend/songs');
    this.setData({
      recommendList: recommendListData.recommend
    })
  },
  //跳转去详情
  toSongDetail(event){
    //从data- 中获取当前下标
    let {song, index} = event.currentTarget.dataset;
    //并且更新data中的index
    this.setData({
      index
    })
    wx.navigateTo({
      url: '/songPages/pages/songDetail/songDetail?musicId='+song.id,
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})
